body{
    /* 内边距 */
    padding: 0px;
    /* 外边距 */
    margin: 0px;
    background: #000000;
}
a{
    /* 定位方式,当前绝对定位 */
    position: absolute;
    top: 50%;
    left: 50%;

    /* 进行2d转化 */
    transform: translate(-50%,-50%);
    width: 200px;
    height: 70px;
    /* 对齐方式居中 */
    text-align: center;
    /* 距离顶部的像素 */
    line-height: 70px;
    color: #fff;
    font-size: 24px;
    /* 设置英文大写 */
    text-transform: uppercase;
    /* 去下划线 */
    text-decoration: none;
    /* 改变字体 */
    font-family: sans-serif;
    box-sizing: border-box;
    /* 背景设置 过度 方向90度 */
    background: linear-gradient(90deg,#03a9f4,#f441a5,#ffeb3b,#03a9f4);
    /* 背景的大小 */
    background-size: 400%;
    /* 圆角 */
    border-radius: 30px;
}

/* 鼠标放置触发 */
a:hover
{
    /* 循环播放 开始结束速度一致 */
    animation: animate 8s linear infinite;
}

@keyframes animate{
    0%
    {   
        /* 设置背景的位置 */
        background-position: 0%;
    }
    100%
    {
        background-position: 400%;
    }
}

a:before
{
    /* 在每个选中对象之前追加内容 */
    content: '';
     /* 定义位置,和层级 */
    position: absolute;
    top: -5px;
    left: -5px;
    right: -5px;
    bottom: -5px;
    z-index: -1;

    /* 渐变 */
    background: linear-gradient(90deg,#03a9f4,#f441a5,#ffeb3b,#03a9f4);
  
    /*  */
    background-size: 400%;   
    border-radius: 40px;
    /* 不透明度 */
    opacity: 0;
    /* 过度动画时间 */
    transition: 0.7s;
    
}
a:hover:before
{   
    /* filter滤镜 blue高斯模糊  */
    filter: blur(20px);
    opacity: 1;
    animation: animate 8s linear infinite;
}
